From: Seth Michael Larson Date: Tue, 20 Jan 2026 20:46:32 +0000 (-0600) Subject: gh-143923: Reject control characters in POP3 commands X-Git-Tag: archive/raspbian/3.9.2-1+rpi1+deb11u6^2^2~4 X-Git-Url: https://dgit.raspbian.org/%22http:/www.example.com/cgi/success//%22mailto:benjaminjkaiser%40gmail.com/%22/%22http:/www.example.com/cgi/success/%22mailto:benjaminjkaiser%40gmail.com/%22?a=commitdiff_plain;h=92bfcc63a75163f36e23bacd5788138e73dba029;p=python3.9.git gh-143923: Reject control characters in POP3 commands Origin: backport, https://github.com/python/cpython/commit/b234a2b67539f787e191d2ef19a7cbdce32874e7 Gbp-Pq: Name CVE-2025-15367.patch --- diff --git a/Lib/poplib.py b/Lib/poplib.py index 0f85873..f563030 100644 --- a/Lib/poplib.py +++ b/Lib/poplib.py @@ -122,6 +122,8 @@ class POP3: def _putcmd(self, line): if self._debugging: print('*cmd*', repr(line)) line = bytes(line, self.encoding) + if re.search(b'[\x00-\x1F\x7F]', line): + raise ValueError('Control characters not allowed in commands') self._putline(line) diff --git a/Lib/test/test_poplib.py b/Lib/test/test_poplib.py index b670afc..f69ac47 100644 --- a/Lib/test/test_poplib.py +++ b/Lib/test/test_poplib.py @@ -15,6 +15,8 @@ from unittest import TestCase, skipUnless from test import support as test_support from test.support import hashlib_helper from test.support import socket_helper +from test.support import control_characters_c0 + HOST = socket_helper.HOST PORT = 0 @@ -359,6 +361,13 @@ class TestPOP3Class(TestCase): self.assertIsNone(self.client.sock) self.assertIsNone(self.client.file) + def test_control_characters(self): + for c0 in control_characters_c0(): + with self.assertRaises(ValueError): + self.client.user(f'user{c0}') + with self.assertRaises(ValueError): + self.client.pass_(f'{c0}pass') + @requires_ssl def test_stls_capa(self): capa = self.client.capa() diff --git a/Misc/NEWS.d/next/Security/2026-01-16-11-43-47.gh-issue-143923.DuytMe.rst b/Misc/NEWS.d/next/Security/2026-01-16-11-43-47.gh-issue-143923.DuytMe.rst new file mode 100644 index 0000000..3cde4df --- /dev/null +++ b/Misc/NEWS.d/next/Security/2026-01-16-11-43-47.gh-issue-143923.DuytMe.rst @@ -0,0 +1 @@ +Reject control characters in POP3 commands.